草庐IT

c++ - gcc 和 libstdc++ 向前兼容

全部标签

c++ - GCC、Unicode 和 __FUNCTION__

我正在尝试让我的项目在GCC下编译(VisualStudio可以完美地编译它)。我有一个自定义断言函数,它会抛出一条wstring消息。它的一部分是__FUNCTION__宏,我使用MSDN中的WIDEN宏将其“统一编码”#defineWIDEN2(x)L##x#defineWIDEN(x)WIDEN2(x)它在MSVC中编译正常,但在GCC中打印如下:error:‘L__FUNCTION__’wasnotdeclaredinthisscope我能想到的唯一解决方案是在运行时使用mbstowcs将__FUNCTION__的内容转换为wstring,但我想找到一种编译时方法来完成它。感谢

c++ - 英特尔编译器与 GCC

当我使用Intel的编译器编译应用程序时,它比使用GCC编译它时慢。英特尔编译器的输出速度要慢2倍以上。该应用程序包含多个嵌套循环。GCC和我遗漏的Intel编译器之间有什么区别吗?我是否需要打开一些其他标志来提高英特尔编译器的性能?我希望英特尔编译器至少与GCC一样快。编译器版本:Intelversion12.0.020101006GCCversion4.4.420100630Thecompilerflagsarethesamewithbothcompilers:-O3-openmp-parallel-mSSE4.2-Wall-pthread 最佳答案

c++ - 简而言之,GCC 选项 -fipa-pta 的作用是什么?

根据GCC手册,-fipa-pta优化会:-fipa-pta:Performinterproceduralpointeranalysisandinterproceduralmodificationandreferenceanalysis.Thisoptioncancauseexcessivememoryandcompile-timeusageonlargecompilationunits.Itisnotenabledbydefaultatanyoptimizationlevel.我假设GCC试图根据过程中使用的指针和引用来区分可变和不可变数据。有更深入的GCC知识的人可以解释一下-fi

c++ - 如何在用 gcc(不是 g++)编译的 C 项目中组合 C++ 目标文件?

又一个C/C++集成问题:我正在尝试使用C++库(我们称之为libcl.a)中的功能更新一些遗留C库(我们称之为libcppl.a)。liblc.a库在我的环境中被广泛使用,并链接到许多C项目中,使用GCC(在C编译器模式下):>>gccprog.c-lcllibcl.a目前包括cl.o目标文件(使用gcc从cl.c+cl.h创建)。libcppl.a由cppl.o组成目标文件(使用g++从cppl.cpp+cppl.h创建)。因为现有的应用程序是用C语言编写的,而构建脚本使用的是GCC,所以我希望尽可能简单地过渡到更新后的库。因此,我想继续使用GCC作为主要编译器,但仍然能够链接到更

c++ - 这是(枚举 : char {}) a gcc bug?

在gcc-4.5下打印0,在gcc-4.6下打印1。#includeenumVenueId:char{};intmain(intargc,char**argv){VenueIdv=(VenueId)'P';std::cout 最佳答案 根据标准,VenuedId具有char类型作为基础类型,因此v应包含char'P',v=='P'应该产生true。§7.2枚举声明Eachenumerationdefinesatypethatisdifferentfromallothertypes.Eachenumerationalsohasanun

c++ - 为什么 "const Eigen::Matrix<>&"和 "const Ref<Eigen::Matrix<>>"显然不兼容?

这是我的示例代码:(请注意#ifENABLE_MY_COMPILE_ERROR包围的部分)#include#include#defineENABLE_MY_COMPILE_ERROR1voidf1(constEigen::Refa,constEigen::Refb,Eigen::Refc){c=a*b;}intmain(intargc,constchar*argv[]){Eigen::Matrix3dM;Eigen::Vector3dx;Eigen::Vector3dy;M.setRandom();x.setRandom();std::cout这是我在ENABLE_MY_COMPILE

c++ - Gcc 预处理器和粘贴

前几天我在stackoverflow上发现了这个片段(感谢):#definePLATFORM3#definePASTER(x,y)x##_##y#defineEVALUATOR(x,y)PASTER(x,y)#definePLATFORMSPECIFIC(fun)EVALUATOR(fun,PLATFORM)externvoidPLATFORMSPECIFIC(somefunc)(char*x);用gcc-E编译,结果是:#1"xx.c"#1""#1""#1"xx.c"externvoidsomefunc_3(char*x);但是:#definePLATFORMlinux#define

c++ - 我不能再将 char[M][N] 类型分配给 gcc 4.9 上的 std::vector

在升级Ubuntu之前我一直使用gcc4.8,现在我有gcc-4.9.1-16。过去可以在没有警告的情况下编译并运行良好的代码现在不再可以编译。staticconstunsignedWIDTH=16;staticconstunsignedVSCALE=1;staticconstunsignedHEIGHT=WIDTH/VSCALE;staticconstunsignedFOOTER=2;typedefcharRow[WIDTH+1];typedefRowWorld[HEIGHT-FOOTER];std::vectorm_levels;Worldlevels[]={{"","","","

c++ - gcc 中的 Borland 风格 __closure

我是使用gnuC++编程的新手。我有一个我认为可以转换为跨平台的应用程序,大约两个月前我开始使用C::B。我有很多问题,但我解决了它们,将原始代码保留在对象类或结构的#ifdefBCB...#else...#endifblock中。我无法解决以下问题,因为它非常复杂。函数声明自1997/1998年以来一直有效,应用程序的每个点都是依赖于这些定义和实现开发的。它们用于对象间、进程间和网络通信以及所有交互事件系统。只要我们的JetRtl.dll准备好服务并且调用者知道参数的数量,任何地方的任何函数都可以使用任意数量(最多50个)的参数直接调用,或通过流连接调用。我解释了这么久,因为据我所知

c++ - GCC 4.9 和 clang 3.5 中的 std::rbegin 和 std::rend 函数

我一直在MSVC2013中使用std::rbegin和std::rend。当我尝试使用GCC4.9.1或clang3.5.0编译我的代码时,两者都告诉我“rbegin”和“rend”是不是命名空间“std”的一部分。请参阅下面的代码示例。我是在做错什么,还是只是尚未在GCC和clang中实现?//test.cpp#include#include#includeintmain(int,char**){std::vectortest={1,2,3,4,5};for(autoit=std::rbegin(test);it!=std::rend(test);++it){std::cout海湾合